package org.bonorsoft.modules.system.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
import org.jeecgframework.poi.excel.annotation.Excel;
import org.springframework.format.annotation.DateTimeFormat;
import org.bonorsoft.common.aspect.annotation.Dict;

import java.io.Serializable;
import java.sql.Blob;
import java.util.Date;

/**
 * <p>
 *
 * </p>
 *
 * @author WilliamYe
 * @since 2020-08-28
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("sys_log")
public class SysLog implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * id
     */
    @TableId(type = IdType.ID_WORKER_STR)
    private String id;

    /**
     * 操作人用户名称
     */
    @Excel(name = "用户名称", width = 15)
    private String username;

    /**
     * 日志类型（1登录日志，2操作日志）
     */
    @Excel(name = "日志类型", dicCode = "log_type", width = 15)
    @Dict(dicCode = "log_type")
    private Integer logType;

    /**
     * 操作类型（1查询，2添加，3修改，4删除,5导入，6导出, 7登陆, 8退出）
     */
    @Excel(name = "操作类型", dicCode = "operate_type", width = 15)
    @Dict(dicCode = "operate_type")
    private Integer operateType;

    /**
     * 操作详细日志
     */
    @Excel(name = "日志内容", width = 15)
    private String logContent;


    /**
     * 更新人
     */
    private String updateBy;

    /**
     * 更新时间
     */
    private Date updateTime;

    /**
     * 耗时
     */
    @Excel(name = "耗时", width = 15)
    private Long costTime;

    /**
     * IP
     */
    @Excel(name = "IP", width = 15)
    private String ip;

    /**
     * 请求参数
     */
    private String requestParam;

    /**
     * 请求类型
     */
    private String requestType;

    /**
     * 请求路径
     */
    private String requestUrl;
    /**
     * 请求方法
     */
    private String method;

    /**
     * 操作人用户账户
     */
    private String userid;

    /**
     * 创建人
     */
    @Excel(name = "创建人", width = 15)
    private String createBy;

    /**
     * 创建时间
     */
    @Excel(name = "更新时间", width = 15, format = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createTime;

    /**
     * 登录地点
     */
    @Excel(name = "登录地点", width = 15)
    private String loginLocation;

    /**
     * 浏览器类型
     */
    @Excel(name = "浏览器类型", width = 15)
    private String browser;

    /**
     * 操作系统
     */
    @Excel(name = "操作系统", width = 15)
    private String os;

}
